#### PRELIMINARY AMENDMENT

104. (Once Amended) An adaptive integrated circuit, comprising:

an executable information module, the module having first configuration information and second configuration information, the module further having operand data;

a plurality of fixed and differing computational elements; and

an interconnection network coupled to the plurality of fixed and differing computational elements, the interconnection network capable of responding to the first configuration information to configure the plurality of fixed and differing computational elements to have an operating system, the operating system further capable of controlling, routing, and timing reconfigurations of the plurality of fixed and differing computational elements for a plurality of functional modes in response to the second configuration information, the plurality of functional modes operative to utilize the operand data.

# **REMARKS**

The present preliminary amendment has been submitted in order to make minor changes in the claims and to make minor changes in the Detailed Description section of the Specification. No new matter has been entered with this preliminary amendment.

If there is any matter that the Examiner would like to discuss, the Examiner is invited to contact the undersigned representative at the telephone number set forth below.

In the event of non-payment or improper payment of the required fee, the Commissioner is authorized to charge or to credit Deposit Account No. 501,262 as may be required to correct the error.

Respectfully submitted,

Paul L. Master et al.

Date: October 17, 2002

By:

Nancy Gamburd

Registration No. 38,147 10 South LaSalle Street

Suite 3300

Chicago, Illinois 60603-1002

(312) 372-2920 Ext.125





On Page 1, starting on line 22, please note the following changes to the paragraph:

This application is related to Paul L. Master et al., U. S. Patent Application Serial No. <u>09/997,530</u>, entitled "Apparatus, System And Method For Configuration Of Adaptive Integrated Circuitry Having Fixed, Application Specific Computational Elements", <u>filed November 30, 2001</u>[concurrently herewith], commonly assigned to QuickSilver Technology, Inc., and incorporated by reference herein, with priority claimed for all commonly disclosed subject matter (the "second related application").

On Page 12, starting on line 5, please note the following changes to the paragraph:

For purposes of explanation and not limitation, the various systems of the present invention, as illustrated in Figure 2, include: system 11 (ACE 100 of wireline device 35 with configuration information or modules 70 in FLASH 10); system 16 (ACE 100 of wireless device 30 with configuration information or modules 70 in silverware storage medium 15); system 31 (ACE 100 of wireless device 32 with configuration information or modules 70 stored in a form of memory (separately illustrated in Figure 3), such as RAM or a matrix interconnection network ("MIN"), discussed below); system 21 (ACE 100 of computer 55B with configuration information or modules 70 stored in computer readable medium 20); system 22 (ACE 100 of server 54B with configuration information or modules 70 stored in a form of memory (separately illustrated in Figure 3)); and system 23 (ACE 100 of router 53B with configuration information or modules 70 stored in a memory (separately illustrated in Figure 3)). As may be apparent, a system of the present invention may be embodied within any device or other article, in addition to those illustrated (e.g., LAN 41, wireless LAN 43, WAN 42, and adjunct network entity 50), which include both an ACE 100 and configuration information (or module 70) for the provision of a corresponding operating mode, and may otherwise be co-extensive with any particular apparatus or other embodiment.

On Page 14, starting on line 1, please note the following changes to the paragraph:

The interface 62 is utilized for appropriate connection to a relevant channel, network or bus; for example, the interface 62 may provide impedance matching, drivers and other functions for a wireline interface, may provide demodulation and analog to



digital conversion for a wireless interface, and may provide a physical interface for the memory 61 with other devices. In general, the interface 62 is used to receive and transmit data, depending upon the selected embodiment, such as voice information, configuration information, silverware modules (70), control messages, authentication data and other pertinent information. The ACE 100 may also be configured to provide the functionality of the interface 62, including internal IC input/output ("I/O") and external (off-chip) I/O, such as for PCI bus control. The memory 61 may be an integrated circuit or portion of an integrated circuit, such as various forms of RAM, DRAM, SRAM, FeRAM, MRAM, ROM, EPROM, EPROM, flash, and so on. For non-IC (or non-SOC) embodiments, the memory 61 may also be a magnetic (hard of floppy) drive, an optical storage device, or any other type of data storage apparatus and, as indicated above, may be distributed across multiple devices. In addition, depending upon the selected embodiment, and as discussed in greater detail below, the memory 61 may also be included within the ACE 100, through memory computational elements or within the matrix interconnection network (MIN). One or more processing elements 65 optionally may be included within system 60, to provide any additional processing capability, such as reduced instruction set ("RISC") processing, or may be included as computational elements within the ACE 100.

On Page 14, starting on line 24, please note the following changes to the paragraph:

Figure 4 is a block diagram illustrating a preferred ACE apparatus 100 embodiment in accordance with the present invention. The ACE 100 is preferably embodied as an integrated circuit, or as a portion of an integrated circuit having other, additional components. (The ACE 100 is also described in detail in the related application.) In the preferred embodiment, and as discussed in greater detail below, the ACE 100 includes one or more reconfigurable matrices (or nodes) 150, such as matrices 150A through 150N as illustrated, and a matrix interconnection network (MIN) 110. Also in the preferred embodiment, and as discussed in detail below, one or more of the matrices 150, such as matrices 150A and 150B, are configured for functionality as a controller 120, while other matrices, such as matrices 150C and 150D, are configured for functionality as a memory 140. While illustrated as separate matrices 150A through



150D, it should be noted that these control and memory functionalities may be, and preferably are, distributed across a plurality of matrices 150 having additional functions to, for example, avoid any processing or memory "bottlenecks" or other limitations. Such distributed functionality, for example, is illustrated in Figure 5. The various matrices 150 and matrix interconnection network 110 may also be implemented together as fractal subunits, which may be scaled from a few nodes to thousands of nodes. As mentioned above, in the preferred embodiment, the [multimode rake receiver] <u>adjunct network entity</u> 50 of the present invention is embodied as an ACE 100 or as one or more matrices 150 (with corresponding interconnection networks).

On Page 15, starting on line 13, please note the following changes to the paragraph:

A significant departure from the prior art, the ACE 100 does not utilize traditional (and typically separate) data, <u>direct memory access ("DMA")</u>, random access, configuration and instruction busses for signaling and other transmission between and among the reconfigurable matrices 150, the controller 120, and the memory 140, or for other [input/output ("]I/O[")] functionality. Rather, data, control (such as power and timing information) and configuration information are transmitted between and among these matrix 150 elements, utilizing the matrix interconnection network 110, which may be configured and reconfigured, to provide any given connection between and among the reconfigurable matrices 150, including those matrices 150 configured as the controller 120 and the memory 140, as discussed in greater detail below.

On Page 16, starting on line 5, please note the following changes to the paragraph:

The matrices 150 configured to function as memory 140 may be implemented in any desired or preferred way, utilizing computational elements (discussed below) of fixed memory elements, and may be included within the ACE 100 or incorporated within another IC or portion of an IC (such as memory 61). In the preferred embodiment, the memory 140 is included within the ACE 100, and preferably is comprised of computational elements which are low power consumption random access memory (RAM), but also may be comprised of computational elements of any other form of memory, such as flash, DRAM, SRAM, MRAM, ROM, EPROM or E<sup>2</sup>PROM. As

mentioned, this memory functionality may also be distributed across multiple matrices 150, and may be temporally embedded, at any given time, as a particular MIN 110 configuration. In addition, in the preferred embodiment, the memory 140 preferably includes [direct memory access (]DMA[)] engines, not separately illustrated.

On Page 17, starting on line 3, please note the following changes to the paragraph:

The matrix interconnection network 110 of Figure 4, and its subset interconnection networks separately illustrated in Figures 5 and 6 (Boolean interconnection network 210, data interconnection network 240, and interconnect 220), collectively and generally referred to herein as "interconnect", "interconnection(s)", "interconnection network(s)" or MIN, may be implemented generally as known in the art, such as utilizing field programmable gate array ("FPGA") interconnection networks or switching fabrics, albeit in a considerably more varied fashion. [(]As used herein, "field programmability" refers to the capability for post-fabrication adding or changing of actual IC functionality, as opposed to programming of existing IC structure or function (such as in a microprocessor or DSP). In the preferred embodiment, the various interconnection networks are implemented as described, for example, in U.S. Patent No. 5,218,240, U.S. Patent No. 5,336,950, U.S. Patent No. 5,245,227, and U.S. Patent No. 5,144,166, and also as discussed below and as illustrated with reference to Figures 8, 9 and 10. These various interconnection networks provide selectable (routable or switchable) connections between and among the controller 120, the memory 140, the various matrices 150, and the computational units 200 and computational elements 250 discussed below, providing the physical basis for the configuration and reconfiguration referred to herein, in response to and under the control of configuration signaling generally referred to herein as "configuration information" (and provided in modules 70). In addition, the various interconnection networks (110, 210, 240 and 220) provide selectable or switchable data, input, output, control and configuration paths, between and among the controller 120, the memory 140, the various matrices 150, and the computational units 200 and computational elements 250, in lieu of any form of traditional or separate input/output busses, data busses, DMA, RAM, configuration and instruction busses.



On Page 21, starting on line 13, please note the following changes to the paragraph:

Next, the present invention also utilizes a tight coupling (or interdigitation) of data and configuration (or other control) information, within a plurality of packets or within one, effectively continuous stream of information. This coupling or commingling of data and configuration information, referred to as "silverware" or as a "silverware" module, is illustrated in Figure 1. This coupling of data and configuration information into one information (or bit) stream, which may be continuous or divided into packets, helps to enable real-time reconfigurability of the ACE 100, without a need for the (often unused) multiple, overlaying networks of hardware interconnections of the prior art. For example, as an analogy, a particular, first configuration of computational elements 250 at a particular, first period of time, as the hardware to execute a corresponding algorithm during or after that first period of time, may be viewed or conceptualized as a hardware analog of "calling" a subroutine in software which may perform the same algorithm. As a consequence, once the configuration of the computational elements 250 has occurred (i.e., is in place), as directed by (a first subset of) the configuration information, the data for use in the algorithm is immediately available as part of the silverware module. Referring to Figure 1, this is illustrated by "calling" various configurations (through references or flags in fields 80 and 81, for example, for configurations "A" and "B"), closely followed by providing the data for use in these configurations (fields 83 and 84 for configuration "A", fields 86 and 87 for configuration "B"). The same computational elements 250 may then be reconfigured for a second period of time, as directed by second configuration information (i.e., a second subset of configuration information), for execution of a second, different algorithm, also utilizing immediately available data. The immediacy of the data, for use in the configured computational elements 250, provides a one or two clock cycle hardware analog to the multiple and separate software steps of determining a memory address and fetching stored data from the addressed registers. This has the further result of additional efficiency, as the configured computational elements 250 may execute, in comparatively few clock cycles, an algorithm which may require orders of magnitude more clock cycles for execution if called as a subroutine in a conventional microprocessor or digital signal processor ("DSP").



Page 22, starting on line 25, please note the following changes to the paragraph:

Referring again to Figure 4, the functions of the controller 120 (preferably matrix (KARC) 150A and matrix (MARC) 150B, configured as finite state machines) may be explained (1) with reference to a silverware module, namely, the tight coupling of data and configuration information within a single stream of information, (2) with reference to multiple potential modes of operation, (3) with reference to the reconfigurable matrices 150, and (4) with reference to the reconfigurable computation units 200 and the computational elements 250 illustrated in Figure 5. As indicated above, through a silverware module, the ACE 100 may be configured or reconfigured to perform a new or additional function, such as an upgrade to a new technology standard or the addition of an entirely new function, such as the addition of a music function to a mobile communication device. Such a silverware module may be stored in the matrices 150 of memory 140, or may be input from an external (wired or wireless) source through, for example, matrix interconnection network 110. In the preferred embodiment, one of the plurality of matrices 150 is configured to decrypt such a module and verify its validity, for security purposes. Next, prior to any configuration or reconfiguration of existing ACE 100 resources, the controller 120, through the matrix (KARC) 150A, checks and verifies that the configuration or reconfiguration may occur without adversely affecting any pre-existing functionality, such as whether the addition of music functionality would adversely affect pre-existing mobile communications functionality. In the preferred embodiment, the system requirements for such configuration or reconfiguration are included within the silverware module or configuration information, for use by the matrix (KARC) 150A in performing this evaluative function. If the configuration or reconfiguration may occur without such adverse affects, the silverware module is allowed to load into the matrices 150 (of memory 140), with the matrix (KARC) 150A setting up the DMA engines within the matrices 150C and 150D of the memory 140 (or other standalone DMA engines of a conventional memory). If the configuration or reconfiguration would or may have such adverse affects, the matrix (KARC) 150A does not allow the new module to be incorporated within the ACE 100.





On Page 28, starting on line 6, please note the following changes to the paragraph:

In the preferred embodiment, the selection of various input and output lines 281 and 291, and the creation of various connections through the interconnect (210, 220 and 240), is under control of control bits 265 from [the] <u>a</u> computational unit controller 255, as discussed below. Based upon these control bits 265, any of the various input enables 251, input selects 252, output selects 253, MUX selects 254, DEMUX enables 256, DEMUX selects 257, and DEMUX output selects 258, may be activated or deactivated.

On Page 28, starting on line 13, please note the following changes to the paragraph:

The exemplary computation unit 200 includes [a] the computation unit controller 255 which provides control, through control bits 265, over what each computational element 250, interconnect (210, 220 and 240), and other elements (above) does with every clock cycle. Not separately illustrated, through the interconnect (210, 220 and 240), the various control bits 265 are distributed, as may be needed, to the various portions of the computation unit 200, such as the various input enables 251, input selects 252, output selects 253, MUX selects 254, DEMUX enables 256, DEMUX selects 257, and DEMUX output selects 258. The CU controller [295] 255 also includes one or more lines 295 for reception of control (or configuration) information and transmission of status information.

On Page 29, starting on line 30, please note the following changes to the paragraph:

Figure 9 is a block diagram illustrating, in greater detail, a preferred core cell 610 of an adaptive logic processor computational unit 600 with a fixed computational element 650, in accordance with the present invention. The fixed computational element is a 3-input[]-[-]2 output function generator 550, separately illustrated in Figure 10. The preferred core cell 610 also includes control logic 655, control inputs 665, control outputs 670 (providing output interconnect), output 675, and inputs (with interconnect muxes) 660 (providing input interconnect).

## MARKED CHANGES TO THE CLAIMS

1. (Once Amended) A system for configuring and operating an adaptive circuit, the system comprising:

a first executable information module, the module having first configuration information and second configuration information, the module further having first operand data and second operand data;

a plurality of heterogeneous computational elements, [the plurality of heterogeneous computational elements including a first computational element and a second computational element, the] a first computational element of the plurality of heterogeneous computational elements having a first fixed architecture and [the] a second computational element of the plurality of heterogeneous computational elements having a second fixed architecture, the first fixed architecture being different than the second fixed architecture; and

an interconnection network coupled to the plurality of heterogeneous computational elements, the interconnection network [operative to configure and provide] <u>capable of configuring and providing</u> the first operand data to the plurality of heterogeneous computational elements for a first functional mode of a plurality of functional modes[,] in response to the first configuration information, and the interconnection network further [operative to reconfigure and provide] <u>capable of reconfiguring and providing</u> the second operand data to the plurality of heterogeneous computational elements for a second functional mode of the plurality of functional modes[,] in response to the second configuration information, the first functional mode being different than the second functional mode.

- 4. (Once Amended) The system of claim 1, further comprising:

  a memory coupled to the plurality of heterogeneous computational elements and to the interconnection network, the memory [operative to store] capable of storing the first configuration information and the second configuration information.
- 12. (Once Amended) The system of claim 1, wherein the first fixed architecture and the second fixed architecture are selected from a plurality of specific architectures, the plurality of specific architectures [including functions for] comprising at least two of the following corresponding functions: memory, addition, multiplication, complex multiplication, subtraction, configuration, reconfiguration, routing, control, input, output, and field programmability.

## MARKED CHANGES TO THE CLAIMS

13. (Once Amended) The system of claim 1, wherein the plurality of functional modes [includes] comprises at least two of the following functional modes: linear algorithmic operations, non-linear algorithmic operations, finite state machine operations, controller operations, memory operations, and bit-level manipulations.

# 14. (Once Amended) The system of claim 1, further comprising:

a controller coupled to the plurality of heterogeneous computational elements and to the interconnection network, the controller [operative to coordinate] <u>capable of coordinating</u> the configuration of the plurality of heterogeneous computational elements for the first functional mode with the first operand data and further [coordinate] <u>coordinating</u> the reconfiguration of the plurality of heterogeneous computational elements for the second functional mode with the second operand data.

- 15. (Once Amended) The system of claim 1, further comprising:
- a second plurality of heterogeneous computational elements coupled to the interconnection network, the second plurality of heterogeneous computational elements configured for a controller operating mode, the second plurality of heterogeneous computational elements [operative to coordinate] capable of coordinating the configuration of the plurality of heterogeneous computational elements for the first functional mode with the first operand data and further [coordinate] coordinating the reconfiguration of the plurality of heterogeneous computational elements for the second functional mode with the second operand data.
- 16. (Once Amended) The system of claim 1, wherein the system is embodied within a mobile station having a plurality of operating modes, the plurality of operating modes [including] comprising at least two of the following modes: a mobile telecommunication mode, a personal digital assistance mode, a multimedia reception mode, a mobile packet-based communication mode, and a paging mode.
- 35. (Once Amended) The module of claim 31, wherein the first information sequence and the second information sequence have a discrete[,] packet form.

## MARKED CHANGES TO THE CLAIMS

- 36. (Once Amended) The module of claim 31, wherein the first information sequence and the second information sequence have a continuous[,] stream form.
- 40. (Once Amended) A method for adaptive configuration and operation, the method comprising:

receiving a first executable information module, the module having first configuration information and second configuration information, the module further having first operand data and second operand data;

in response to the first configuration information, configuring through an interconnection network and providing the first operand data to a plurality of heterogeneous computational elements for a first functional mode of a plurality of functional modes, [the plurality of heterogeneous computational elements including a first computational element and a second computational element, the] <u>a</u> first computational element <u>of the plurality of heterogeneous computational elements</u> having a first fixed architecture and [the] <u>a</u> second computational element <u>of the plurality of heterogeneous computational elements</u> having a second fixed architecture, the first fixed architecture being different than the second fixed architecture; and

in response to the second configuration information, reconfiguring through the interconnection network and providing the second operand data to the plurality of heterogeneous computational elements for a second functional mode of the plurality of functional modes, the first functional mode being different than the second functional mode.

- 46. (Once Amended) The method of claim 40, further comprising:
  storing the first [plurality of] configuration information as a configuration of the plurality of heterogeneous computational units.
- 52. (Once Amended) The method of claim 40, wherein the first fixed architecture and the second fixed architecture are selected from a plurality of specific architectures, the plurality of specific architectures [including functions for] comprising at least two of the following corresponding functions: memory, addition, multiplication, complex multiplication, subtraction, configuration, reconfiguration, control, input, output, routing, and field programmability.

## MARKED CHANGES TO THE CLAIMS

- 53. (Once Amended) The method of claim 40, wherein the plurality of functional modes [includes] comprising at least two of the following functional modes: linear algorithmic operations, non-linear algorithmic operations, finite state machine operations, controller operations, memory operations, and bit-level manipulations.
- 55. (Once Amended) The method of claim 40, wherein the method is operable within a mobile station having a plurality of operating modes, the plurality of operating modes [including] comprising at least two of the following modes: a mobile telecommunication mode, a personal digital assistance mode, a multimedia reception mode, a mobile packet-based communication mode, and a paging mode.
- 64. (Once Amended) A method for adaptive configuration, the method comprising: transmitting a first executable information module, the module having first configuration information and second configuration information, the module further having first operand data and second operand data;

wherein when a first executable information module is received, an interconnection network coupled to a plurality of heterogeneous computational elements is [operative to configure and provide] capable of configuring and providing the first operand data to the plurality of heterogeneous computational elements for a first functional mode of a plurality of functional modes[,] in response to the first configuration information, and the interconnection network further [operative to reconfigure and provide] capable of reconfiguring and providing the second operand data to the plurality of heterogeneous computational elements for a second functional mode of the plurality of functional modes[,] in response to the second configuration information, the first functional mode being different than the second functional mode; and

wherein the plurality of heterogeneous computational elements include a first computational element and a second computational element, the first computational element having a first fixed architecture and the second computational element having a second fixed architecture, the first fixed architecture being different than the second fixed architecture.

74. (Once Amended) The method of claim 64, wherein the first fixed architecture and the second fixed architecture are selected from a plurality of specific architectures, the plurality



### MARKED CHANGES TO THE CLAIMS

of specific architectures [including functions for] <u>comprising at least two of the following</u> <u>functions:</u> memory, addition, multiplication, complex multiplication, subtraction, configuration, reconfiguration, control, input, output, and field programmability.

- 75. (Once Amended) The method of claim 64, wherein the plurality of functional modes [includes] comprises at least two of the following functional modes: linear algorithmic operations, non-linear algorithmic operations, finite state machine operations, memory operations, and bit-level manipulations.
- 90. (Once Amended) The adaptive integrated circuit of claim 88, wherein the plurality of functional modes [includes] comprises at least two of the following functional modes: linear algorithmic operations, non-linear algorithmic operations, finite state machine operations, controller operations, memory operations, and bit-level manipulations.
- 93. (Once Amended) The adaptive integrated circuit of claim 88, wherein the plurality of fixed and differing computational elements are selected from a plurality of specific architectures, the plurality of specific architectures [including functions for] comprising at least two of the following corresponding functions: memory, addition, multiplication, complex multiplication, subtraction, configuration, reconfiguration, control, input, output, and field programmability.
- 99. (Once Amended) An adaptive integrated circuit, comprising:

a plurality of executable information modules, [the plurality executable information modules including a first executable information module and a second executable information module, the] a first executable information module of the plurality of executable information modules and [the] a second executable information module of the plurality of executable information modules each having corresponding operand data;

a plurality of reconfigurable matrices, the plurality of reconfigurable matrices including a plurality of heterogeneous computation units, each heterogeneous computation unit of the plurality of heterogeneous computation units formed from a selected configuration, of a plurality of configurations, of a plurality of fixed computational elements, the plurality of fixed computational elements including a first computational element having a first architecture and a



### MARKED CHANGES TO THE CLAIMS

second computational element having a second architecture, the first architecture distinct from the second architecture, the plurality of heterogeneous computation units coupled to an interconnect network and reconfigurable in response to the plurality of executable information modules; and

a matrix interconnection network coupled to the plurality of reconfigurable matrices, the matrix interconnection network [operative to configure] <u>capable of configuring</u> the plurality of reconfigurable matrices in response to the first executable information module for a first operating mode and to provide corresponding operand data to the plurality of reconfigurable matrices for the first operating mode, and [to reconfigure] <u>capable of reconfiguring</u> the plurality of reconfigurable matrices in response to the second executable information module for a second operating mode and to provide corresponding operand data to the plurality of reconfigurable matrices for the second operating mode.

100. (Once Amended) The adaptive integrated circuit of claim 99, further comprising: a controller coupled to the plurality of reconfigurable matrices, the controller [operative to provide] capable of providing the plurality of executable information modules to the reconfigurable matrices and to the matrix interconnection network.

102. (Once Amended) An adaptive integrated circuit, comprising:

a first executable information module, the module having first configuration information and second configuration information, the module further having first operand data and second operand data;

a plurality of heterogeneous computational elements, [the plurality of heterogeneous computational elements including a first computational element and a second computational element, the] a first computational element of the plurality of heterogeneous computational elements having a first fixed architecture and [the] a second computational element of the plurality of heterogeneous computational elements having a second fixed architecture, the first fixed architecture being different than the second fixed architecture;

an interconnection network coupled to the plurality of heterogeneous computational elements, the interconnection network [operative to configure] <u>capable of configuring</u> the plurality of heterogeneous computational elements for a first functional mode of a plurality of





functional modes[,] in response to the first configuration information, and [to provide] <u>capable of providing</u> the first operand data to the plurality of heterogeneous computational elements for the first operating mode, and the interconnection network further [operative to reconfigure] <u>capable of reconfiguring</u> the plurality of heterogeneous computational elements for a second functional mode of the plurality of functional modes[,] in response to the second configuration information, the first functional mode being different than the second functional mode, and [to provide] <u>capable of providing</u> the second operand data to the plurality of heterogeneous computational elements for the second operating mode;

wherein a first subset of the plurality of heterogeneous computational elements is configured for a controller operating mode, the controller operating mode [including functions for] comprising at least two of the following corresponding functions: directing configuration and reconfiguration of the plurality of heterogeneous computational elements, [for] selecting the first configuration information and the second configuration information from the first executable information module, and [for] coordinating the configuration and reconfiguration of the plurality of heterogeneous computational elements with respective first operand data and second operand data; and

wherein a second subset of the plurality of heterogeneous computational elements is configured for a memory operating mode for storing the first configuration information and the second configuration information.

# 103. (Once Amended) An adaptive integrated circuit, comprising:

a first executable information module, the module having first configuration information and second configuration information, the module further having first operand data and second operand data;

a plurality of heterogeneous computational elements, [the plurality of heterogeneous computational elements including a first computational element and a second computational element, the] a first computational element of the plurality of heterogeneous computational elements having a first fixed architecture of a plurality of fixed architectures and [the] a second computational element of the plurality of heterogeneous computational elements having a second fixed architecture of [a] the plurality of fixed architectures, the first fixed architecture being different than the second fixed architecture, and the plurality of fixed architectures [including



functions for] <u>comprising at least two of the following functions:</u> memory, addition, multiplication, complex multiplication, subtraction, configuration, reconfiguration, control, input, output, and field programmability; and

an interconnection network coupled to the plurality of heterogeneous computational elements, the interconnection network [operative to configure] capable of configuring the plurality of heterogeneous computational elements for a first functional mode of a plurality of functional modes[,] in response to the first configuration information, the interconnection network further [operative to reconfigure] capable of reconfiguring the plurality of heterogeneous computational elements for a second functional mode of the plurality of functional modes[,] in response to the second configuration information, the first functional mode being different than the second functional mode, and the plurality of functional modes [including] comprising at least two of the following functional modes: linear algorithmic operations, non-linear algorithmic operations, finite state machine operations, memory operations, and bit-level manipulations, and the interconnection network further [operative to respectively provide] capable of respectively providing first operand data and second operand data to the plurality of heterogeneous computational elements for the first functional mode and for the second functional mode.

104. (Once Amended) An adaptive integrated circuit, comprising: an executable information module, the module having first configuration information and

second configuration information, the module further having operand data;

a plurality of fixed and differing computational elements; and

an interconnection network coupled to the plurality of fixed and differing computational elements, the interconnection network [operative in response] capable of responding to the first configuration information to configure the plurality of fixed and differing computational elements to have an operating system, the operating system further [operative to control, route and time] capable of controlling, routing, and timing reconfigurations of the plurality of fixed and differing computational elements for a plurality of functional modes in response to the second configuration information, the plurality of functional modes operative to utilize the operand data.